1

jQuery 实现Ajax应用

使用load()方法异步请求数据

使用load()方法通过Ajax请求加载服务器中的数据,并把返回的数据放置到指定的元素中,它的调用格式为:

load(url,[data],[callback])

参数url为加载服务器地址,可选项data参数为请求时发送的数据,callback参数为数据请求成功后,执行的回调函数

使用getJSON()方法异步加载JSON格式数据

使用getJSON()方法可以通过Ajax异步请求的方式,获取服务器中的数据,并对获取的数据进行解析,显示在页面中,它的调用格式为:

jQuery.getJSON(url,[data],[callback])或$.getJSON(url,[data],[callback])

其中,url参数为请求加载json格式文件的服务器地址,可选项data参数为请求时发送的数据,callback参数为数据请求成功后,执行的回调函数

使用getScript()方法异步加载并执行js文件

使用getScript()方法异步请求并执行服务器中的JavaScript格式的文件,它的调用格式如下所示:

jQuery.getScript(url,[callback])或$.getScript(url,[callback])

参数url为服务器请求地址,可选项callback参数为请求成功后执行的回调函数

使用get()方法以GET方式从服务器获取数据

使用get()方法时,采用GET方式向服务器请求数据,并通过方法中回调函数的参数返回请求的数据,它的调用格式如下:

$.get(url,[callback])

参数url为服务器请求地址,可选项callback参数为请求成功后执行的回调函数

使用post()方法以POST方式从服务器发送数据

post()方法用于以POST方式向服务器发送数据,服务器接收到数据之后,进行处理,并将处理结果返回页面,调用格式如下:

$.post(url,[data],[callback])

参数url为服务器请求地址,可选项data为向服务器请求时发送的数据,可选项callback参数为请求成功后执行的回调函数

使用serialize()方法序列化表单元素值

使用serialize()方法可以将表单中有name属性的元素值进行序列化,生成标准URL编码文本字符串,直接可用于ajax请求,它的调用格式如下:

$(selector).serialize()

其中selector参数是一个或多个表单中的元素或表单元素本身

使用ajax()方法加载服务器数据

使用ajax()方法是最底层、功能最强大的请求服务器数据的方法,它不仅可以获取服务器返回的数据,还能向服务器发送请求并传递数值,它的调用格式如下:

jQuery.ajax([settings])或$.ajax([settings])

其中参数settings为发送ajax请求时的配置对象,在该对象中,url表示服务器请求的路径,data为请求时传递的数据,dataType为服务器返回的数据类型,success为请求成功的执行的回调函数,type为发送数据请求的方式,默认为get

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
    <head>
        <title>使用ajax()方法加载服务器数据</title>
        <script src="http://libs.baidu.com/jquery/1.9.0/jquery.js" type="text/javascript"></script>
        <link href="style.css" rel="stylesheet" type="text/css" />
    </head>
    
    <body>
        <div id="divtest">
            <div class="title">
                <span class="fl">检测数字的奇偶性</span> 
                <span class="fr">
                    <input id="btnCheck" type="button" value="检测" />
                </span>
            </div>
            <ul>
               <li>请求输入一个数字 
                   <input id="txtNumber" type="text" size="12" />
               </li>
            </ul>
        </div>
        
        <script type="text/javascript">
            $(function () {
                $("#btnCheck").bind("click", function () {
                    $.ajax({
                        url: "http://www.imooc.com/data/check.php",
                        data: { num: $("#txtNumber").val() },
                        type: 'POST',
                        success: function (data) {
                            $("ul").append("<li>你输入的<b>  "
                            + $("#txtNumber").val() + " </b>是<b> "
                            + data + " </b></li>");
                        }
                    });
                })
            });
        </script>
    </body>
</html>

使用ajaxSetup()方法设置全局Ajax默认选项

使用ajaxSetup()方法可以设置Ajax请求的一些全局性选项值,设置完成后,后面的Ajax请求将不需要再添加这些选项值,它的调用格式为:

jQuery.ajaxSetup([options])或$.ajaxSetup([options])

可选项options参数为一个对象,通过该对象设置Ajax请求时的全局选项值

<script type="text/javascript">
    $(function () {
        $.ajaxSetup({
            type:"post",
            dataType:"text",
            success:function(data){
                $("ul").append("<li>你输入的<b>  "
                + $("#txtNumber").val() + " </b>是<b> "
                + data + " </b></li>");
            }
        });
        $("#btnShow_1").bind("click", function () {
            $.ajax({
                data: { num: $("#txtNumber").val() },
                url: "http://www.imooc.com/data/check.php"
            });
        })
        $("#btnShow_2").bind("click", function () {
            $.ajax({
                data: { num: $("#txtNumber").val() },
                url: "http://www.imooc.com/data/check_f.php"
            });
        })
    });
</script>

使用ajaxStart()和ajaxStop()方法

ajaxStart()和ajaxStop()方法是绑定Ajax事件。ajaxStart()方法用于在Ajax请求发出前触发函数,ajaxStop()方法用于在Ajax请求完成后触发函数。它们的调用格式为:

$(selector).ajaxStart(function())和$(selector).ajaxStop(function())

其中,两个方法中括号都是绑定的函数,当发送Ajax请求前执行ajaxStart()方法绑定的函数,请求成功后,执行ajaxStop ()方法绑定的函数

jQuery 常用插件

表单验证插件——validate

该插件自带包含必填、数字、URL在内容的验证规则,即时显示异常信息,此外,还允许自定义验证规则,插件调用方法如下:

$(form).validate({options})

其中form参数表示表单元素名称,options参数表示调用方法时的配置对象,所有的验证规则和异常信息显示的位置都在该对象中进行设置

<script type="text/javascript">
    $(function () {
        $("#frmV").validate(
            {
                /*自定义验证规则*/
                rules: {
                    email: {
                        required: true,
                        email: true
                        }
                    },
                /*错误提示位置*/
                errorPlacement: function (error, element) {
                    error.appendTo(".tip");
                }
            }
        );
    });
</script>

表单插件——form

通过表单form插件,调用ajaxForm()方法,实现ajax方式向服务器提交表单数据,并通过方法中的options对象获取服务器返回数据,调用格式如下:

$(form). ajaxForm ({options})

其中form参数表示表单元素名称;options是一个配置对象,用于在发送ajax请求过程,设置发送时的数据和参数

<script type="text/javascript">
    $(function () {
        var options = {
        url: "http://www.imooc.com/data/form_f.php", 
        target: ".tip"
        }
        $(#frmV).ajaxForm(options);
    });
</script>

图片灯箱插件——lightBox

该插件可以用圆角的方式展示选择中的图片,使用按钮查看上下张图片,在加载图片时自带进度条,还能以自动播放的方式浏览图片,调用格式如下:

$(linkimage).lightBox({options})

其中linkimage参数为包含图片的<a>元素名称,options为插件方法的配置对象

图片放大镜插件——jqzoom

在调用jqzoom图片放大镜插件时,需要准备一大一小两张一样的图片,在页面中显示小图片,当鼠标在小图片中移动时,调用该插件的jqzoom()方法,显示与小图片相同的大图片区域,从而实现放大镜的效果,调用格式如下:

$(linkimage).jqzoom({options})

其中linkimage参数为包含图片的<a>元素名称,options为插件方法的配置对象

<script type="text/javascript">
    $(function () {
        $("#jqzoom").jqzoom({ //绑定图片放大插件jqzoom
            zoomWidth: 123, //小图片所选区域的宽
            zoomHeight: 123, //小图片所选区域的高
            zoomType: 'reverse' //设置放大镜的类型
        });
    });
</script>

cookie插件——cookie

使用cookie插件后,可以很方便地通过cookie对象保存、读取、删除用户的信息,还能通过cookie插件保存用户的浏览记录,它的调用格式为:

保存:$.cookie(key,value);读取:$.cookie(key),删除:$.cookie(key,null)

其中参数key为保存cookie对象的名称,value为名称对应的cookie值

<script type="text/javascript">
    $(function () {
        if ($.cookie("email")) {
            $("#email").val($.cookie("email"));
        }
        $("#btnSet").bind("click", function () {
            if ($("#chksave").is(":checked")) {
                $.cookie("email", $("email").val(), {
                    path: "/", expires: 7
                })
            }
            else {
                $.cookie("email", null, {
                    path: "/"
                })
            }
        });
    });
</script>

搜索插件——autocomplete

搜索插件的功能是通过插件的autocomplete()方法与文本框相绑定,当文本框输入字符时,绑定后的插件将返回与字符相近的字符串提示选择,调用格式如下:

$(textbox).autocomplete(urlData,[options]);

其中,textbox参数为文本框元素名称,urlData为插件返回的相近字符串数据,可选项参数options为调用插件方法时的配置对象

<body>
    <div id="divtest">
        <div class="title">
            <span class="fl">搜索插件</span>
        </div>
        <div class="content">
            <span class="fl">用户名</span><br />
            <input id="txtSearch" name="txtSearch" type="text" />
            <div class="tip">
            </div>
        </div>
    </div>
    
    <script type="text/javascript">
        $(function () {
            var arrUserName = ["王五", "刘明", "李小四", "刘促明", "李渊", "张小三", "王小明"];
            $("#txtSearch").autocomplete(arrUserName, {
                minChars: 0, //双击空白文本框时显示全部提示数据
                formatItem: function (data, i, total) {
                    return "<I>" + data[0] + "</I>"; //改变匹配数据显示的格式
                },
                formatMatch: function (data, i, total) {
                    return data[0];
                },
                formatResult: function (data) {
                    return data[0];
                }
            }).result(SearchCallback); 
            function SearchCallback(event, data, formatted) {
                $(".tip").show().html("您的选择是:" + (!data ? "空" : formatted));
            }
        });
    </script>
</body>

右键菜单插件——contextmenu

右键菜单插件可以绑定页面中的任意元素,绑定后,选中元素,点击右键,便通过该插件弹出一个快捷菜单,点击菜单各项名称执行相应操作,调用代码如下:

$(selector).contextMenu(menuId,{options});

Selector参数为绑定插件的元素,meunId为快捷菜单元素,options为配置对象

<body>
    <div id="divtest">
        <div class="title"><span class="fl">点击右键</span></div>
        <div class="content">
            <input id="btnSubmit" type="button" value="提交" />
            <div class="tip"></div>
        </div>
        <div class="contextMenu" id="sysMenu">
            <ul>
                <li id="Li3"><img src="http://img.mukewang.com/52e4b34b0001bb6d00160016.jpg" alt="" />保存</li>
                <li id="Li4"><img src="http://img.mukewang.com/52e4b3680001424900160016.jpg" alt="" />退出</li>
            </ul>
        </div>
    </div>
    
    <script type="text/javascript">
        $(function () {
            $("#divtest").contextMenu('sysMenu',
              { bindings:
                 {
                     'Li3': function (Item) {
                         $(".tip").show().html("您点击了“保存”项");
                     },
                     'Li4': function (Item) {
                         $(".tip").show().html("您点击了“退出”项");
                     }
                 }
              });
        });
    </script>
</body>

自定义对象级插件——lifocuscolor插件

自定义的lifocuscolor插件可以在<ul>元素中,鼠标在表项<li>元素移动时,自定义其获取焦点时的背景色,即定义<li>元素选中时的背景色,调用格式为:

$(Id).focusColor(color)

其中,参数Id表示<ul>元素的Id号,color表示<li>元素选中时的背景色

<body>
    <div id="divtest">
        <div class="title">
            <span class="fl">对象级别的插件</span>
        </div>
        <div class="content">
            <ul id="u1">
                <li><span>橘子</span><span>水果</span></li>
                <li><span>芹菜</span><span>蔬菜</span></li>
                <li><span>香蕉</span><span>水果</span></li>
            </ul>
        </div>
    </div>
    
    <script type="text/javascript">
        $(function () {
            $("#u1").focusColor("#888"); //调用自定义的插件
        })
    </script>
</body>

自定义类级别插件—— twoaddresult

通过调用自定义插件twoaddresult中的不同方法,可以实现对两个数值进行相加和相减的运算,导入插件后,调用格式分别为:

$.addNum(p1,p2) 和 $.subNum(p1,p2)

上述调用格式分别为计算两数值相加和相减的结果,p1和p2为任意数值

<body>
    <div id="divtest">
        <div class="title">
            <span class="fl">自定义类级别插件</span> 
            <span class="fr">
                <input id="btnCount" type="button" value="计算" />
            </span>
        </div>
        <div class="content">
            两数相减:
            <input id="Text1" type="text" class="txt" />
            -
            <input id="Text2" type="text" class="txt" />
            =
            <input id="Text3" type="text" class="txt" />
        </div>
    </div>
    
    <script type="text/javascript">
        $(function () {
            $("#btnCount").bind("click", function () {
                $("#Text3").val(
                    $.subNum($("#Text1").val(),
                        $("#Text2").val())
                );
            });
        });
    </script>
</body>

布still
461 声望32 粉丝

数据挖掘、用户行为研究、用户画像